home *** CD-ROM | disk | FTP | other *** search
/ PC World Komputer 2010 April / PCWorld0410.iso / hity wydania / Ubuntu 9.10 PL / karmelkowy-koliberek-desktop-9.10-i386-PL.iso / casper / filesystem.squashfs / usr / share / system-tools-backends-2.0 / scripts / UsersConfig.pm < prev   
Text File  |  2009-10-20  |  3KB  |  91 lines

  1. #-*- Mode: perl; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
  2.  
  3. # DBus object for the Users list
  4. #
  5. # Copyright (C) 2005 Carlos Garnacho
  6. #
  7. # Authors: Carlos Garnacho Parro  <carlosg@gnome.org>
  8. #
  9. # This program is free software; you can redistribute it and/or modify
  10. # it under the terms of the GNU Library General Public License as published
  11. # by the Free Software Foundation; either version 2 of the License, or
  12. # (at your option) any later version.
  13. #
  14. # This program is distributed in the hope that it will be useful,
  15. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  17. # GNU Library General Public License for more details.
  18. #
  19. # You should have received a copy of the GNU Library General Public License
  20. # along with this program; if not, write to the Free Software
  21. # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
  22.  
  23. package UsersConfig;
  24.  
  25. use base qw(StbObject);
  26. use Net::DBus::Exporter ($Utils::Backend::DBUS_PREFIX);
  27. use Users::Users;
  28. use Users::Shells;
  29.  
  30. my $OBJECT_NAME = "UsersConfig";
  31. my $OBJECT_PATH = "$Utils::Backend::DBUS_PATH/$OBJECT_NAME";
  32. my $format = [[ "array", [ "struct", "string", "string", "int32", "int32", [ "array", "string"], "string", "string" ]],
  33.               ["array", "string" ], "int32", "int32", "int32", "string", "string", "int32" ];
  34.  
  35. sub new
  36. {
  37.   my $class = shift;
  38.   my $self  = $class->SUPER::new ($OBJECT_PATH, $OBJECT_NAME);
  39.  
  40.   bless $self, $class;
  41.  
  42.   return $self;
  43. }
  44.  
  45. dbus_method ("get", [], $format);
  46. dbus_method ("set", $format, []);
  47.  
  48. sub get
  49. {
  50.   my ($self) = @_;
  51.   my $logindefs, $users, $use_md5, $shells;
  52.   $self->SUPER::reset_counter ();
  53.  
  54.   $use_md5 = &Users::Users::get_use_md5 ();
  55.   $logindefs = &Users::Users::get_logindefs ();
  56.   $users = &Users::Users::get ();
  57.   $shells = &Users::Shells::get ();
  58.  
  59.   return ($users, $shells, $use_md5, $$logindefs{"umin"},
  60.           $$logindefs{"umax"}, $$logindefs{"home_prefix"},
  61.           $$logindefs{"shell"}, $$logindefs{"group"});
  62. }
  63.  
  64. sub set
  65. {
  66.   my ($self, @config) = @_;
  67.   $self->SUPER::reset_counter ();
  68.  
  69.   Users::Users::set ($config[0]);
  70.   Users::Shells::set ($config[1]);
  71.   Users::Users::set_logindefs ({"umin"        => $config[3],
  72.                                 "umax"        => $config[4],
  73.                                 "home_prefix" => $config[5],
  74.                                 "shell"       => $config[6],
  75.                                 "group"       => $config[7]});
  76. }
  77.  
  78. sub getFiles
  79. {
  80.   my ($self) = @_;
  81.   my ($files);
  82.  
  83.   $files = &Users::Users::get_files ();
  84.  
  85.   return ($files);
  86. }
  87.  
  88. my $config = UsersConfig->new ();
  89.  
  90. 1;
  91.